/**
 *  fileName:移动零
 *  time:2019-12-10
 *  todo:给定一个数组 nums，编写一个函数将所有 0 移动到数组的末尾，同时保持非零元素的相对顺序。

 示例:

 输入: [0,1,0,3,12]
 输出: [1,3,12,0,0]
 说明:

 必须在原数组上操作，不能拷贝额外的数组。
 尽量减少操作次数。

 来源：力扣（LeetCode）
 链接：https://leetcode-cn.com/problems/move-zeroes
 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */

/**
 * @param {number[]} nums
 * @return {void} Do not return anything, modify nums in-place instead.
 */
var moveZeroes = function(nums) {
  let ind = 0
  let num = 0
  let len = nums.length
  while (ind+num<len){
    if(nums[ind]===0){
      nums.splice(len,0,0)
      nums.splice(ind,1)
      num ++
    }else{
      ind ++
    }
  }
};
